導(dǎo)讀:使用全局變量 在初始化代碼的時(shí)候,小程序會讀取一個app.js的文件,在這里我們可以定義我們所需要的全局變量。});//page.js ...var app = getApp()var getFoo = app.globalData
發(fā)表日期:2019-10-20
文章編輯:興田科技
瀏覽次數(shù):8973
標(biāo)簽:
在微信小程序的開發(fā)中,我們會經(jīng)常遇到頁面間數(shù)據(jù)傳遞或者相互影響的問題。在實(shí)際的開發(fā)過程中,可以通過以下幾種方法來實(shí)現(xiàn)。
使用全局變量
全局變量實(shí)際上是定義了一個全局的對象,并在每個頁面中引入。
在初始化代碼的時(shí)候,小程序會讀取一個app.js的文件,在這里我們可以定義我們所需要的全局變量。
//app.js ...App({globalData: {foo:'bar' }
});
然后在頁面中,可以通過getApp()方法獲取到全局應(yīng)用對象,可以對全局變量進(jìn)行讀取并更改:
//page.js ...var app = getApp()var getFoo = app.globalData.foo app.globalData.foo ='fun'
由于app.js在項(xiàng)目中是用來做基礎(chǔ)配置的,因此不建議將很多變量放在這里配置。一般情況下會將一些持久化的常量配置在這里,對于經(jīng)常需要變動的量不建議用這個方法。
使用本地緩存
本地緩存是微信小程序提供的一個功能,可以將用戶產(chǎn)生的數(shù)據(jù)做本地的持久化,類似于 NoSQL,可以進(jìn)行讀取和修改的操作。
那么在不同的頁面之間,如何利用它,進(jìn)行數(shù)據(jù)的交互呢?
假設(shè)我們在 A 頁面保存了用戶的信息。
// pageA.js...var developer = {
name:'raymond',
gender:'male' }
wx.setStorageSync('developer', developer);
這樣做,這個數(shù)據(jù)就存在了本地。當(dāng)在 B 頁面需要使用的時(shí)候,可以直接的獲取到數(shù)據(jù)池中的數(shù)據(jù),并進(jìn)行 CRUD 操作:
//pageB.js ...// Retrievevar developer = (wx.getStorageSync('developer') || [])// Update developer.name ='Jiayang' wx.setStorageSync('developer', developer);// Delete wx.removeStorage({
key:'developer' })
需要注意的是,在回到 A 頁面的時(shí)候,小程序需要重新讀取數(shù)據(jù)。這時(shí)候,可以選擇放在生命周期的onShow中對數(shù)據(jù)重新加載
父級往子級頁面(模板)的數(shù)據(jù)傳遞
我們通常會在頁面之間進(jìn)行跳轉(zhuǎn)、重定向的操作。這時(shí)候,我們可以選擇將部分?jǐn)?shù)據(jù)放在url里面,并在新頁面onLoad的時(shí)候進(jìn)行初始化。
pageC.js ...// Navigatewx.navigateTo({url:'../pageD/pageD?name=raymond&gender=male',
})// Redirectwx.redirectTo({url:'../pageD/pageD?name=raymond&gender=male',
})
在 D 頁面中,我們可以這樣接收到到所傳進(jìn)來的參數(shù):
// pageD.js ...
page({
onl oad: function(option){
console.log(option.name +'is' +option.gender)
this.setData({option:option })
}
})
wx.navigateTo和wx.redirectTo不允許跳轉(zhuǎn)到 tab 所包含的頁面,只能用wx.switchTab跳轉(zhuǎn)。需要注意的是,wx.switchTab中的url不能傳參數(shù)。
微信新提供的wx.reLaunch接口可以傳入?yún)?shù)。
另外,在頁面中我們通常會用到一些組件模板,因此在父子之間也會有相應(yīng)的數(shù)據(jù)傳遞。
使用name屬性,作為模板的名字。然后在這里面使用is屬性,聲明需要的使用的模板。
{{index}}: {{msg}}Time: {{time}}
然后將模板所需要的data傳入,如:
<templateis="msgItem"data="{{...item}}"/>
page({data: {item: {index:0,msg:'this is a template',time:'2016-09-15' }
}
})
傳入模板的除了變量,還可以是事件方法對象。例如,模板中的點(diǎn)擊事件,可以傳遞到使用模板的元素中。
通過獲取到頁面對象進(jìn)行數(shù)據(jù)操作
這個方法的精髓,是通過獲取到其他頁面的對象原型,然后通過原型方法setData對當(dāng)前對象管理的data進(jìn)行修改,示例如下:
//pageE.js ...page({data: {index:1 }
})
當(dāng)跳轉(zhuǎn)到下一個頁面 F 之后,假定在 F 中有操作需要對 E 中的數(shù)據(jù)有修改,則可以使用以下方法:
pageF.js
...
page({
changeIndexInE:function(){var pages = getCurrentpages();var prevpage = pages[pages.length -2];
prevpage.setData({
index:0 })
}
})
這個方法可以操作頁面堆棧里面的頁面的數(shù)據(jù),可以做到讓后一級頁面對上級頁面群的數(shù)據(jù)管理。
小結(jié)
在微信小程序中有以上并且不局限于以上幾種的方式進(jìn)行頁面間數(shù)據(jù)傳遞、交互,在實(shí)際應(yīng)用中可以組合使用。比如說:
●一些常量,可以交由app.js管理;需要持久化的量可以放在本地保存。
●涉及到下級頁面或者模板元素的數(shù)據(jù),可以通過傳入?yún)?shù)的方式傳入。
●后級頁面可以通過獲取堆棧里的頁面對象快速修改上級的數(shù)據(jù)。
在實(shí)際應(yīng)用中結(jié)合使用,可以更好地管理小程序的數(shù)據(jù)。
本文如有不周到之處,可以留言進(jìn)行討論。
更多新聞
2023
在網(wǎng)站開發(fā)和測試完成后,進(jìn)行最后的上線和推廣階段。在此階段,確保域名和托管服務(wù)設(shè)置正確,并利用社交媒體和其他在線渠道宣傳網(wǎng)站。
View details
2023
哈爾濱網(wǎng)站優(yōu)化是指通過一系列技術(shù)和策略,以提升網(wǎng)站的質(zhì)量和相關(guān)性,從而使得網(wǎng)站在搜索引擎結(jié)果頁面中獲得更高的排名。網(wǎng)站優(yōu)化可以包括優(yōu)化網(wǎng)站的內(nèi)容、結(jié)構(gòu)、代碼和外部鏈接等多個方面。通過采用哈爾濱網(wǎng)站優(yōu)化的方法,企業(yè)可以提高網(wǎng)站的可訪問性和提升用戶體驗(yàn),同時(shí)增加網(wǎng)站的流量和曝光度。
View details
2023
雖然東營網(wǎng)站優(yōu)化可以顯著提高您的網(wǎng)站排名,但無法保證排名第一。排名是由搜索引擎算法綜合考慮多個因素來確定的,包括網(wǎng)站質(zhì)量、關(guān)鍵詞競爭度和搜索用戶行為等。
View details
2023
興化網(wǎng)站優(yōu)化是一個長期的過程,因此需要一定的時(shí)間和耐心。通常情況下,要看到明顯的結(jié)果可能需要幾個月的時(shí)間,具體結(jié)果還會受到競爭對手、行業(yè)趨勢等多種因素的影響。
View details